Product Code Database
Example Keywords: nokia -final $58
   » » Wiki: Glibc
Tag Wiki 'Glibc'.
Tag

The GNU C Library, commonly known as glibc, is the implementation of the C standard library. It provides a wrapper around the system calls of the and other kernels for application use. Despite its name, it now also directly supports C++ (and, indirectly, other programming languages). It was started in the 1980s by the Free Software Foundation (FSF) for the operating system.

glibc is released under the GNU Lesser General Public License. The GNU C Library project provides the core libraries for the GNU system, as well as many systems that use as the kernel. These libraries provide critical including C11, POSIX.1-2008, BSD, OS-specific APIs and more. These APIs include such foundational facilities as open, read, write, , printf, , , , crypt, , exit and more.


History
Minimum for Linux Standard Base (LSB) 3.0
Minimum for LSB 4.0, initial support
Full support. RHEL5 end of support was
Minimum for LSB 5.0. Initial psiginfo support.
SLES11 reached end of long-term support in March 2022.
x32 ABI support, ISO C11 compliance,
64-bit ARM support
Improved C++11 support. Support for Intel TSX lock elision. Support for the Xilinx and IBM POWER8 microarchitectures.
SystemTap probes for . GNU Indirect Function (IFUNC) support for ppc32 and ppc64. New feature test macro _DEFAULT_SOURCE to replace _SVID_SOURCE and _BSD_SOURCE. Preliminary safety documentation for all functions in the manual. ABI change in ucontext and jmp_buf for s390/s390x.
Support for file description locks
New semaphore implementation
Support to enable Google Native Client (NaCl), that originally ran on x86, running on ARMv7-A, 7.0
8.0
Some deprecated features have been removed
The getentropy and getrandom functions, and the <sys/random.h> header file have been added.
Improved performance (per-thread cache for malloc), Unicode 10 support
Performance optimizations. support.
statx, renameat2, Unicode 11.0.0
  • getcpu wrapper
  • build and install all locales as directories with files
  • optimized trigonomical functions
  • Transactional Lock Elision for powercp64le ABI
  • posix_spawn_file_actions_addchdir_np and posix_spawn_file_actions_addfchdir_np
  • popen and system do not run atfork handlers anymore
  • support for the C-SKY ABIV2 running on Linux
  • strftime's default formatting of a locale's alternative year; the '_' and '-' flags can now be applied to its "%EY"
Unicode 12.1.0, the dynamic linker accepts the --preload argument to preload shared objects, the gettid function has been added on Linux, Minguo (Republic of China) calendar support, new Japanese era added to ja_JP locale, memory allocation functions fail with total object size larger than PTRDIFF_MAX; fixed
Initial C23 standard support
Unicode 13.0, 'access' attribute for better warnings in GCC 10, i.e. to "help detect buffer overflows and other out-of-bounds accesses"
HWCAPS
libpthread, libdl, libutil, libanl has been integrated into libc.
Unicode 14.0, C.UTF-8 locale, restartable sequences. Removed support.
The strlcpy and strlcat functions added. libmvec support for ARM64.
The stdbit.h header has been added from ISO C2X. Support for shadow stacks on x86_64, new security features, and the removal of libcrypt.
Partial support for the ISO C23 standard, a new tunable for the testing of programs, improved 64-bit ARM vector support.
Add , , functions.
New math functions, support for arbitrary baud rates in the termios.h interface, SFrame-based stack tracing.

The glibc project was initially written mostly by Roland McGrath, working for the Free Software Foundation (FSF) in the summer of 1987 as a teenager. In February 1988, FSF described glibc as having nearly completed the functionality required by . By 1992, it had the ANSI C-1989 and POSIX.1-1990 functions implemented and work was under way on POSIX.2. In September 1995 Ulrich Drepper made his first contribution to the glibc and by 1997 most commits were made by him. Drepper held the maintainership position for many years and until 2012 accumulated 63% of all commits to the project.

In May 2009, glibc was migrated to a repository.

In 2010, a licensing issue was resolved which was caused by the implementation in glibc that was not GPL compatible. It was fixed by re-licensing the Sun RPC components under the .

In 2014, glibc suffered from an ABI breakage bug on s390.

In July 2017, 30 years after he started glibc, Roland McGrath announced his departure, "declaring myself maintainer emeritus and withdrawing from direct involvement in the project. These past several months, if not the last few years, have proven that you don't need me anymore".

In 2018, maintainer Raymond Nicholson removed a joke about from the glibc source code. It was restored later by Alexandre Oliva after demanded to have it returned.

In 2021, the assignment requirement to the Free Software Foundation was removed from the project.


Fork and variant
In 1994, the developers of the forked glibc. Their fork, "Linux libc", was maintained separately until around 1998. Because the copyright attribution was insufficient, changes could not be merged back to the GNU Libc. When the FSF released glibc 2.0 in January 1997, the kernel developers discontinued Linux libc due to glibc 2.0's superior compliance with POSIX standards. glibc 2.0 also had better internationalization and more in-depth translation, IPv6 capability, 64-bit data access, facilities for multithreaded applications, future version compatibility, and the code was more portable. The last-used version of Linux libc used the internal name () . Following on from this, glibc 2.x on Linux uses the soname

In 2009, and a number of derivatives switched from glibc to the variant eglibc.

(2025). 9781787124455, Packt Publishing. .
Eglibc was supported by a consisting of Freescale, MIPS, and Wind River. It contained changes that made it more suitable for and had added support for architectures that were not supported by glibc, such as the PowerPC e500. The code of eglibc was merged back into glibc at version 2.20.
(2025). 9781787288850
Since 2014, eglibc is discontinued. The and Debian also moved back to glibc since the release of .
(2025). 9781784395193


Steering committee
Starting in 2001 the library's development had been overseen by a committee, with Ulrich Drepper kept as the lead contributor and maintainer. The steering committee installation was surrounded by a public controversy, as it was openly described by Ulrich Drepper as a failed maneuver by . rms-accused-of-attempting-glibc-hostile-takeover on .com on 19 August 2001

In March 2012, the steering committee voted to disband itself and remove Drepper in favor of a community-driven development process, with Ryan Arnold, Maxim Kuvyrkov, Joseph Myers, Carlos O'Donell, and Alexandre Oliva holding the responsibility of GNU maintainership (but no extra decision-making power).


Functionality
glibc provides the functionality required by the Single UNIX Specification, (1c, 1d, and 1j) and some of the functionality required by ISO C11, ISO C99, (BSD) interfaces, the System V Interface Definition (SVID) and the X/Open Portability Guide (XPG), Issue 4.2, with all extensions common to XSI (X/Open System Interface) compliant systems along with all X/Open UNIX extensions.

In addition, glibc also provides extensions that have been deemed useful or necessary while developing .


Supported hardware and kernels
glibc is used in systems that run many different kernels and different hardware architectures. Its most common use is in systems using the on x86 hardware, however, officially supported hardware includes: , ARC, , , IA-64, Motorola m68k, , MIPS, , , , , s390, , and x86 (old versions support TILE). It officially supports the and kernels. Additionally, there are heavily patched versions that run on the kernels of and (from which Debian GNU/kFreeBSD and Debian GNU/NetBSD systems are built, respectively), as well as a forked-version of . It is also used (in an edited form) and named in and Haiku.


Use in small devices
glibc has been criticized as being "" and slower than other libraries in the past, e.g. by and programmers. For this reason, several alternative C standard libraries have been created which emphasize a smaller footprint. However, many small-device projects use GNU libc over the smaller alternatives because of its application support, standards compliance, and completeness. Examples include and for iPaq handhelds (when using the GPE display software).


Secure string functions
glibc does not implement bounds-checking interfaces defined in C11 and did not implement and until 2023 on the grounds that "in practice these functions can cause trouble, as their intended use encourages silent data truncation, adds complexity and inefficiency, and does not prevent all buffer overruns in the destinations." The FAQ pointed out that the bounds-checking interfaces were optional in the ISO standard and that snprintf was available as an alternative.


Compatibility layers
There are compatibility layers ("shims") to allow programs written for other ecosystems to run on glibc interface offering systems. These include libhybris, a compatibility layer for Android's Bionic, and Wine, which can be seen as a compatibility layer from APIs to glibc and other native APIs available on Unix-like systems.


See also


Notes

External links

Page 1 of 1
1
Page 1 of 1
1

Account

Social:
Pages:  ..   .. 
Items:  .. 

Navigation

General: Atom Feed Atom Feed  .. 
Help:  ..   .. 
Category:  ..   .. 
Media:  ..   .. 
Posts:  ..   ..   .. 

Statistics

Page:  .. 
Summary:  .. 
1 Tags
10/10 Page Rank
5 Page Refs
1s Time